IFW

# IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

IN RE APPLICATION OF: Kenji SAKAUF, et al.

SERIAL NO: 10/787,183

FILED:

February 27, 2004

FOR:

ECC CONTROL APPARATUS

GAU:

2185

**EXAMINER:** 

# REQUEST FOR PRIORITY

COMMISSIONER FOR PATENTS ALEXANDRIA, VIRGINIA 22313

|                                                                                                                            | •                                                                        |                                   |                                  |
|----------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------|-----------------------------------|----------------------------------|
| SIR:                                                                                                                       |                                                                          |                                   |                                  |
| ☐ Full benefit of the filing provisions of 35 U.S.C.                                                                       | date of U.S. Application Serial Number §120.                             | , filed ,                         | is claimed pursuant to the       |
| ☐ Full benefit of the filing §119(e):                                                                                      | date(s) of U.S. Provisional Application(s) is <u>Application No.</u>     | claimed pursuar <u>Date Filed</u> | nt to the provisions of 35 U.S.C |
| Applicants claim any rig<br>the provisions of 35 U.S.                                                                      | nt to priority from any earlier filed application. §119, as noted below. | ons to which the                  | y may be entitled pursuant to    |
| In the matter of the above-ide                                                                                             | entified application for patent, notice is herel                         | by given that the                 | applicants claim as priority:    |
| <u>COUNTRY</u><br>JAPAN                                                                                                    | APPLICATION NUMBER 2003-054686                                           |                                   | <u>H/DAY/YEAR</u><br>y 28, 2003  |
| JAPAN                                                                                                                      | 2004-016180                                                              |                                   | 23, 2004                         |
| □ are submitted herewit □ will be submitted prio □ were filed in prior app □ were submitted to the Receipt of the certifie | or to payment of the Final Fee                                           |                                   | ler PCT Rule 17.1(a) has been    |
| ☐ (B) Application Seria ☐ are submitted h                                                                                  |                                                                          | l No. file                        | ed ; and                         |
|                                                                                                                            | Re                                                                       | espectfully Subr                  | nitted,                          |
|                                                                                                                            | O                                                                        | BLON, SPIVAK                      | K, McCLELLAND,                   |

Customer Number

22850

Tel. (703) 413-3000 Fax. (703) 413-2220 (OSMMN 05/03) OBLON, SPIVAK, McCLELLAND, MAIER & NEUSTADT, P.C.

Marvin J. Spivak

Registration No. 24,913

Joseph A. Scafetta, Jr. Registration No. 26, 803



別紙添付の書類に記載されている事項は下記の出願書類に記載されている事項と同一であることを証明する。

This is to certify that the annexed is a true copy of the following application as filed with this Office.

出 願 年 月 日 Date of Application:

2003年 2月28日

出 願 番 号 Application Number:

特願2003-054686

[ST. 10/C]:

[JP2003-054686]

出 願 人
Applicant(s):

東芝マイクロエレクトロニクス株式会社

株式会社東芝

2003年 8月12日

特許庁長官 Commissioner, Japan Patent Office





【書類名】 特許願

【整理番号】 A000206164

【提出日】 平成15年 2月28日

【あて先】 特許庁長官 殿

【国際特許分類】 H01L 21/00

【発明の名称】 ECC制御装置

【請求項の数】 16

【発明者】

【住所又は居所】 神奈川県川崎市川崎区駅前本町25番地1 東芝マイク

ロエレクトロニクス株式会社内

【氏名】 坂上 健二

【発明者】

【住所又は居所】 神奈川県川崎市幸区小向東芝町1番地 株式会社東芝マ

イクロエレクトロニクスセンター内

【氏名】 助川 博

【発明者】

【住所又は居所】 神奈川県川崎市川崎区駅前本町25番地1 東芝マイク

ロエレクトロニクス株式会社内

【氏名】 角田 仁

【特許出願人】

【識別番号】 000221199

【氏名又は名称】 東芝マイクロエレクトロニクス株式会社

【特許出願人】

【識別番号】 000003078

【氏名又は名称】 株式会社 東芝

【代理人】

【識別番号】

100058479

【弁理士】

【氏名又は名称】 鈴江 武彦

【電話番号】

03-3502-3181

【選任した代理人】

【識別番号】

100091351

【弁理士】

【氏名又は名称】 河野 哲

【選任した代理人】

【識別番号】 100088683

【弁理士】

【氏名又は名称】 中村 誠

【選任した代理人】

【識別番号】 100108855

【弁理士】

【氏名又は名称】 蔵田 昌俊

【選任した代理人】

【識別番号】

100084618

【弁理士】

【氏名又は名称】 村松 貞男

【選任した代理人】

【識別番号】

100092196

【弁理士】

【氏名又は名称】 橋本 良郎

【手数料の表示】

【予納台帳番号】 011567

【納付金額】

21,000円

# 【提出物件の目録】

【物件名】 明細書 1

【物件名】 図面 1

【物件名】 要約書 1

【包括委任状番号】 9105411

【包括委任状番号】 9705037

【プルーフの要否】 要

【書類名】

明細書

【発明の名称】

ECC制御装置

【特許請求の範囲】

【請求項1】 ホストとの間でデータの入力及び出力を行う第1の入出力回路と、

前記第1の入出力回路により入力された所定のブロック単位の書き込みブロックデータのうち、所定単位の保護領域データとそれ以外の冗長領域データとを検出する検出回路と、

前記検出回路により検出された保護領域データに対してエラー訂正符号を生成する生成回路と、

前記検出回路により検出された冗長領域データに前記生成回路により生成されたエラー訂正符号を挿入する訂正符号挿入回路と、

メモリとの間でデータの入力及び出力を行う第2の入出力回路とを具備することを特徴とするECC制御装置。

【請求項2】 前記訂正符号挿入回路は、前記冗長領域のうち所定の位置に前記エラー訂正符号を挿入することを特徴とする請求項1に記載のECC制御装置。

【請求項3】 前記生成回路は、前記保護領域データと、前記冗長領域のうち前記エラー訂正符号を挿入する直前までのデータとに対してエラー訂正符号を生成することを特徴とする請求項2に記載のECC制御装置。

【請求項4】 前記第2の入出力回路により入力された上記所定のブロック 単位の読み込みブロックデータに対してデータ誤り検出演算を行う演算回路と、

前記演算回路によりデータ誤りが検出された場合に、訂正に必要な訂正情報を 作成する訂正回路とをさらに具備することを特徴とする請求項3に記載のECC 制御装置。

【請求項5】 前記演算回路によりデータ誤りが検出された場合に、誤りデータ数が予め決められたデータ数以上であるか否かを判定する判定回路と、

前記判定回路により予め決められたデータ数以上であると判定された場合に、 訂正不可能である旨を表す異常終了情報を作成する作成回路とをさらに具備する ことを特徴とする請求項4に記載のECC制御装置。

【請求項6】 前記第1の入出力回路により入力された書き込みデータ転送中を示す書込可能信号のパルスをカウントするカウンタと、

前記カウンタによりカウントされた値が予め決められた値になった時に、前記書込可能信号のパルスをマスクすることにより前記書込可能信号から第1のクロックを生成するクロック生成回路とをさらに具備することを特徴とする請求項1に記載のECC制御装置。

【請求項7】 前記カウンタは、前記第1の入出力回路により入力された読み込みデータ転送中を示す読出可能信号のパルスをカウントする機能をさらに具備し、

前記クロック生成回路は、前記カウンタによりカウントされた値が予め決められた値になった時に、前記読出可能信号のパルスをマスクすることにより前記読出可能信号から第2のクロックを生成することを特徴とする請求項6に記載のECC制御装置。

【請求項8】 前記カウンタは、前記第1の入出力回路によりデータのアドレス情報を示すアドレス信号が入力された場合にパルスのカウントを開始することを特徴とする請求項6又は7に記載のECC制御装置。

【請求項9】 前記メモリにアクセス中であることを示すアクセス可能信号のアサートを継続するモードであるアクセス継続モードを備え、前記ホストから当該モードが選択された場合に、前記メモリに対してアクセス可能信号のアサートを継続して行うアクセス継続回路をさらに具備することを特徴とする請求項1に記載のECC制御装置。

【請求項10】 ホストに対して割り込みを通知するための割込信号を前記第1の入出力回路より前記ホストに対して出力する際に、前記訂正情報或いは前記異常終了情報を含むエラーステータス情報を前記第1の入出力回路より出力するよう制御するエラー情報割込回路をさらに具備することを特徴とする請求項5に記載のECC制御装置。

【請求項11】 前記ホストより指定されるブロックデータのフォーマット 情報に基づいて前記生成回路により生成されたエラー訂正符号を書き込む領域を 特定する領域特定回路をさらに具備し、

前記訂正符号挿入回路は、前記領域特定回路により特定された領域に前記エラー訂正符号を挿入することを特徴とする請求項1に記載のECC制御装置。

【請求項12】 当該ECC制御装置に対して予め決められた命令を表す専用コマンドが前記第1の入出力回路より入力された場合に、前記専用コマンドを実行し、かつ前記専用コマンドを前記メモリに通知しないよう制御する専用コマンド回路をさらに具備することを特徴とする請求項1に記載のECC制御装置。

【請求項13】 前記第1の入出力回路により入力された信号の遅延時間を調整する遅延調整回路をさらに具備することを特徴とする請求項1に記載のEC C制御装置。

【請求項14】 前記遅延調整回路は、前記ホストが前記メモリを制御する制御信号に対して遅延時間を調整することを特徴とする請求項13に記載のEC C制御装置。

【請求項15】 前記第1の入出力回路より入力された書き込みデータ或いは前記第2の入出力回路より入力された読み込みデータを、前記遅延調整回路により遅延時間を調整された制御信号に基づいてラッチする第1のラッチ回路をさらに具備したことを特徴とする請求項13に記載のECC制御装置。

【請求項16】 前記第1の入出力回路より入力された書き込みデータ或いは前記第2の入出力回路より入力された読み込みデータを、前記第1の入出力回路より入力された制御信号に基づいてラッチする第2のラッチ回路をさらに具備したことを特徴とする請求項15に記載のECC制御装置。

# 【発明の詳細な説明】

 $[0\ 0\ 0\ 1\ ]$ 

# 【発明の属する技術分野】

この発明は、ホストからのデータをメモリに記憶し、またはメモリに記憶したデータをホストに読み出す時に用いられるECC (Error Check and Correct)制御装置に係り、特にホストとメモリとの間のバスを中断して挿入されるECC制御装置に関する。

[0002]

# 【従来の技術】

半導体メモリ、例えばメモリカードにおいて、内蔵されるメモリセルが記憶できる値を2値から多値に変更することで、メモリカードの大容量化が進められている。しかし、メモリセルに多値を用いたメモリカード(以後、多値メモリカードという)では、データの書き込み及び消去の繰り返しによるメモリセルの劣化により、記憶データの信頼性が2値メモリカードに比べて低下してしまう。

# [0003]

このようなメモリセルの信頼性の低下を防止するための方法として、新たなエラー訂正手段を備えた記憶装置が提案されている(例えば、特許文献1)。

[0004]

### 【特許文献1】

特開2000-349652号公報

[0005]

### 【発明が解決しようとする課題】

ところが、新たなエラー訂正手段を追加するには、メモリカード或いはメモリカードにデータの書き込み等を行うホストの回路変更等を行う必要がある。また、ホストの回路変更を行った場合に、エラー訂正のためにホストの負担が増大する不都合が生じる場合がある。このような事情は一般のホストとメモリの関係についても同様である。

### [0006]

本発明は、上記のような事情に鑑みてなされたもので、ホスト或いはメモリにおける既存の回路等を変更することなく、且つホストの負担を増やすことなくE CCの機能強化が可能なECC制御装置を提供することを目的とする。

[0007]

#### 【課題を解決するための手段】

この発明の一態様によれば、ホストとの間でデータの入力及び出力を行う第1 の入出力回路と、前記第1の入出力回路により入力された所定のブロック単位の 書き込みブロックデータのうち、所定単位の保護領域データとそれ以外の冗長領 域データとを検出する検出回路と、前記検出回路により検出された保護領域デー タに対してエラー訂正符号を生成する生成回路と、前記検出回路により検出された冗長領域データに前記生成回路により生成されたエラー訂正符号を挿入する訂正符号挿入回路と、メモリとの間でデータの入力及び出力を行う第2の入出力回路とを具備することを特徴とするECC制御装置が提供される。

# [0008]

## 【発明の実施の形態】

以下、本発明の実施の形態について図面を参照して説明する。

### [0009]

図1は、この実施形態の全体構成を表すブロック図である。

本実施形態では、メモリカードとして例えばNANDフラッシュメモリ2を用いている。ホスト3は、例えばパーソナルコンピュータからなり、上記NANDフラッシュメモリ2にデータの書き込み、データの読み込み等を行う。さらに、上記ホスト3とNANDフラッシュメモリ2との間に、ECCコントローラ1を備えている。

## [0010]

上記ホスト3とECCコントローラ1とは、8ビットの双方向バスFDH[7:0](以後、バスFDHと表す)と、4ビットのチップイネーブル(CE[3:0])信号の信号線5と、リードイネーブル(RE)信号及びライトイネーブル(WE)信号の信号線6と、アドレスラッチイネーブル(ALE)信号及びコマンドラッチイネーブル(CLE)信号の信号線7とにより接続される。バス及び信号線のビット数は上記に限定されるものではない。上記バスFDHは、上記ECCコントローラ1に設けられたIOレジスタ(図示せず)にアクセス時のデータ転送に用いるデータバスである。上記ホスト3は、NANDフラッシュメモリ2に対するコマンドデータ、アドレスデータ及びライトデータをバスFDHに出力する。また上記ホスト3は、NANDフラッシュメモリ2から出力されたリードデータ及びNANDフラッシュメモリ2内部ステータス情報等をバスFDHを介して読み込む。また上記ホスト3は、上記ECCコントローラ1から出力されるエラー訂正情報等をバスFDHを介して読み込む。

#### $[0\ 0\ 1\ 1]$

上記CE[3:0]信号は、上記ホスト3が上記NANDフラッシュメモリ2にアクセス中であることを示す信号である。上記RE信号は、上記バスFDHをリードデータが転送中であることを示す信号である。上記WE信号は、上記バスFDHをライトデータが転送中であることを示す信号である。上記ALE信号は、上記バスFDHをアドレスデータが転送中であることを示す信号である。上記CLE信号は、上記バスFDHをコマンドデータが転送中であることを示す信号である。

# [0012]

上記ECCコントローラ1とNANDフラッシュメモリ2とは、8ビットの双方向バスFDN[7:0] (以後、バスFDNと表す)と、4ビットのチップイネーブル (CEo[3:0]) 信号の信号線8と、リードイネーブル (REo) 信号及びライトイネーブル (WEo) 信号の信号線9と、アドレスラッチイネーブル (ALEo) 信号及びコマンドラッチイネーブル (CLEo) 信号の信号線10により接続される。上記ECCコントローラ1から出力される各イネーブル信号は、上記ホスト3から出力される各イネーブル信号に基づいて生成される。この生成処理については後述する。

## [0013]

上記NANDフラッシュメモリ2とホスト3とは、レディー/ビジー(R/B)信号の信号線11と、その他信号の信号線12により接続される。なお、ECCコントローラ1を挿入する場合と挿入しない場合とで変更のない信号は、図1中のその他信号として表示している。上記R/B信号は、上記NANDフラッシュメモリ2のレディー或いはビジー状態を表す信号である。上記NANDフラッシュメモリ2からデータを読み出す場合、ホスト3はリードコマンドを発行した後、上記NANDフラッシュメモリ2がレディーになった時点でデータの読み込みが可能となる。一方、上記NANDフラッシュメモリ2へデータを書き込む場合、ホスト3は自動プログラムコマンドを発行した後、上記NANDフラッシュメモリ2がレディーになった時点で次のデータの書き込みが可能となる。

#### $[0\ 0\ 1\ 4]$

図2は、ECCコントローラ1の内部構成を示すブロック図である。同図において、データパス/訂正回路100は、ライトデータ及びリードデータのデータパス処理と、ECCコードの生成及びデータ訂正等の処理を行う。イネーブルイ

ンターフェース/クロックジェネレータ回路 200は、各イネーブル信号の遅延時間調整と、RE信号及びWE信号からのクロック生成を行う。カウンタ400は、RE信号またはWE信号のパルスをカウントし、カウント値を制御回路 300に送出する。

### [0015]

制御回路300は、上記データパス/訂正回路100及びイネーブルインターフェース/クロックジェネレータ回路200が行う処理に必要な制御信号を生成し、この生成した制御信号を上記2つの回路に出力する。

## [0016]

また上記制御回路300は、バスの監視機能を備え、この機能により上記バスFDH及びバスFDNの入出力データを監視する。ECCコントローラ1の入出力データがない時は、これらのバスFDHあるいはFDNにデータを送出しない。これは、制御回路300が、制御信号NOUTE及びHOUTEを生成し、図4に示すデータパス/訂正回路100内のトライステートバッファ106及び111を制御することにより行う。

# [0017]

さらに上記制御回路300は、クロックモード制御機能301と、CEモード制御機能302と、ECC領域制御機能303と、エラー割り込み制御機能304と、専用コマンド実行モード制御機能305とを備える。

#### $[0\ 0\ 1\ 8]$

クロックモード制御機能301は、通常のクロックモードとWE/REクロック代用モードとの制御を行う。ECCコントローラ1は、ホスト3から取得したクロックを使用する通常のクロックモードと、RE信号及びWE信号を使用してECCコントローラ1の動作に必要なクロック(CLK)を生成するWE/REクロック代用モードとを備える。上記クロックモード制御機能301は、上記2つのモードの選択を行う。また、上記WE/REクロック代用モードが選択された場合には、上記カウンタ400によるカウント値を使用して、上記RE信号及びWE信号を厳密なタイミングでマスクすることでCLKを生成する。

# [0019]

CEモード制御機能302は、ダイナミックCEモードとスタティックCEモードとを制御する。ECCコントローラ1は、チップイネーブルのモードとして、ホスト3から入力される上記CE[3:0]信号に基づいて上記CEo[3:0]信号を生成するダイナミックCEモードと、ECCコントローラ1が擬似的なチップイネーブル信号を生成するスタティックCEモードとを備える。上記CEモード制御機能302は、上記2つのモードの選択を行う。また上記CEモード制御機能302は、上記スタティックCEモードが選択された場合に、スタティックCE信号を生成してNANDフラッシュメモリ2に出力する。

# [0020]

ECC領域制御機能303は、ECCコントローラ1が生成したECCコードを挿入するデータ上の位置を、後述する各データフォーマットに基づいて変更する。また、上記ECC領域制御機能は、ECCコードを挿入するタイミングを制御し、このタイミングに基づいて制御信号NDOSを生成する。

## [0021]

エラー割り込み制御機能304は、ホスト3に対して割り込みモードでエラー 訂正処理を行う場合、割り込み信号をアサートすると同時に割り込み内容情報を 生成して上記バスFDHに出力し続ける。ホスト3が当該割り込みを受け付けるの を検出すると、割り込み内容情報の出力を省略し、エラーアドレス等のエラー情 報の出力を行う。

### [0022]

専用コマンド実行モード制御機能305は、ホスト3から入力されるECCコントローラ1用の命令として定義された専用コマンドを検出すると、所定のコマンドを実行する。さらに、上記専用コマンドをマスクして、NANDフラッシュメモリ2に出力されないように処理を行う。

# [0023]

図3は、イネーブルインターフェース/クロックジェネレータ回路(以後、EI/CG回路という)200の回路構成を示すブロック図である。

上記EI/CG回路200に入力されたCE[3:0]信号は、インバータ回路20 1とセレクタ202に入力される。なお前述したように、当該ECCコントロー ラ1は、チップイネーブルのモードとしてダイナミックCEモードとスタティックCEモードとを備える。通常、ECCコントローラ1はダイナミックCEモードで動作する。このダイナミックCEモードでは、上記セレクタ202はホスト3から入力される上記CE[3:0]信号をスルー出力する。スタティックCEモードについては後述する。上記セレクタ202から出力された信号は、遅延回路203により所定時間遅延され、バッファ204を介して信号線8からCEo[3:0]として出力される。上記インバータ回路201から出力された信号(CEiN)は、ゲート回路207とゲート回路215とに入力される。

### [0024]

上記EI/CG回路200に入力されたWE信号は、遅延回路205とゲート回路207とセレクタ208とAND回路221とに入力される。上記遅延回路205に入力されたWE信号は、所定時間遅延され、バッファ206を介してクロックWE\_CLKとして出力される。上記ゲート回路207から出力された信号は、セレクタ208に入力される。上記セレクタ208は、ダイナミックCEモードでは上記WE信号を選択する。上記セレクタ208から出力された信号は、NOR回路209に入力される。上記NOR回路209は、上記セレクタ208から入力された信号を、上記制御回路300から入力されるMSK\_WE信号に基づいてマスクした信号を出力する。上記NOR回路209から出力された信号は、遅延回路210により所定時間遅延され、インバータ回路211に入力される。上記インバータ回路211から出力された信号は、一方はWEo信号として、もう一方はバッファ212を介してクロックWEo\_CLKとして出力される。

#### [0025]

上記EI/CG回路200に入力されたRE信号は、遅延回路213とゲート回路215とセレクタ216と上記AND回路221とに入力される。上記遅延回路213に入力されたRE信号は、所定時間遅延され、バッファ214を介してクロックRE\_CLKとして出力される。上記ゲート回路215から出力された信号は、セレクタ216に入力される。上記セレクタ216は、ダイナミックCEモードでは上記RE信号を選択する。上記セレクタ216から出力された信号は、NOR回路217に入力される。上記NOR回路217は、上記セレクタ216から入

力された信号を、上記制御回路 3 0 0 から入力されるMSK\_RE信号に基づいてマスクした信号を出力する。上記 NOR回路 2 1 7 から出力された信号は、遅延回路 2 1 8 により所定時間遅延され、インバータ回路 2 1 9 に入力される。上記インバータ回路 2 1 9 から出力された信号は、一方はREo信号として、もう一方はバッファ 2 1 2 を介してクロックREo\_CLKとして出力される。

## [0026]

上記WE信号とRE信号が入力された上記AND回路221から出力された信号は、セレクタ222に入力される。上記セレクタ222は、上記AND回路221から入力されたデータと上記ダイレクトクロック(DCLK)とのいずれかを、上記制御回路300から入力されるDCLKSEL信号に基づいて選択する。上記セレクタ222から出力されたデータは、遅延回路223により所定時間遅延され、バッファ224を介してCLKとして出力される。

## [0027]

上記EI/CG回路200に入力されたCLE信号は、遅延回路225により所定時間遅延され、バッファ226を介してCLE0信号として出力される。上記EI/CG0回路200に入力されたALE1信号は、遅延回路227により所定時間遅延され、バッファ228を介してALE0信号として出力される。

#### [0028]

上記遅延回路 2 0 3, 2 0 5, 2 1 0, 2 1 3, 2 1 8, 2 2 3, 2 2 5, 2 2 7 の遅延時間は、ECCコントローラ1の内部遅延を同一に揃え、かつホスト 3 のバスタイミングを保つことができる値に設定される。

#### [0029]

図4は、データパス/訂正回路100の回路構成を示す図である。

上記バスFDHから入力されたデータは、バッファ101に入力される。上記バッファ101から出力されたデータは、信号線FDHI[7:0]を介してセレクタ105とフリップフロップ102に入力される。上記フリップフロップ102は、クロックWE\_CLKに基づいて入力データのラッチを行う。上記フリップフロップ102から出力されたデータは、信号線HDI\_WEi[7:0]を介してセレクタ103とセレクタ112に入力される。上記セレクタ112に入力されたデータは、制御回路

300から入力される制御信号DINSにより選択され、信号線DIN[7:0]を介して訂正符号/シンドローム回路113に入力される。

## [0030]

上記訂正符号/シンドローム回路113は、ホスト3からNANDフラッシュメモリ2に書き込むライトデータに対して、ECCコード(符号化方式として、例えばリードソロモン符号)を生成する。この生成されたECCコードは、信号線CODE[7:0]を介して上記セレクタ103に入力される。上記セレクタ103は、制御回路300から入力される制御信号NDOSに基づいて、上記信号線HDI\_WEi[7:0]のデータに上記ECCコードを挿入する。上記セレクタ103から出力されたデータは、フリップフロップ104に入力される。

# [0031]

上記フリップフロップ104は、クロックWEo\_CLKに基づいて入力データのラッチを行う。上記フリップフロップ104から出力されたデータは、信号線NDO\_WEoN[7:0]を介してセレクタ105に入力される。上記セレクタ105は、制御回路300から入力される制御信号FDHISに基づいて、信号線FDHI[7:0]のデータを出力するか、或いは信号線NDO\_WEoN[7:0]のデータを出力するかを選択する。上記セレクタ105から出力されたデータは、トライステートバッファ106に入力される。上記トライステートバッファ106は、制御回路300から入力される制御信号NOUTEに基づいてデータの出力を行う。上記トライステートバッファ106から出力されたデータは、上記バスFDNから上記NANDフラッシュメモリ2へ出力される。

#### [0032]

一方、上記バスFDNから入力された読み出しデータは、バッファ107に入力される。なお、上記バッファ101,107は、外部回路との相互作用防止等のために用いる。上記バッファ107から出力されたデータは、信号線NDHI[7:0]を介してフリップフロップ108に入力される。上記フリップフロップ108は、クロックRE\_CLKに基づいて入力データのラッチを行う。上記フリップフロップ108から出力されたデータは、信号線NDI\_REo[7:0]を介してセレクタ109とセレクタ112に入力される。上記セレクタ112に入力されたデータは、制御

回路300から入力される制御信号DINSにより選択され、信号線DIN[7:0]を介して訂正符号/シンドローム回路113に入力される。

## [0033]

上記訂正符号/シンドローム回路113は、ホスト3がNANDフラッシュメモリ2から読み出すリードデータに対して、シンドローム演算を実行する。このシンドローム演算の結果作成されたシンドロームは、訂正回路114に入力される。上記訂正回路114は、上記入力されたシンドロームを基にデータに誤りがあるか否かを判定する。データ誤りがなければ、正常に読み込みが行われた旨の正常終了情報を作成し、この情報を出力する。

### [0034]

一方、データ誤りがあった場合は、上記訂正回路114は誤りデータのアドレスと訂正に必要なデータ情報とからなる訂正情報を作成する。さらに、上記訂正回路114は、訂正処理が正常に終了した旨の訂正終了情報を作成し、上記訂正終了情報を出力し、続いて上記訂正情報を出力する。ところで、データ誤りがあった場合において、上記訂正回路114は、後述する所定値以上のエラーを検出した場合には訂正不可能であると判定する。そして上記訂正回路114は、上記訂正不可能である旨の異常終了情報を作成し、この異常終了情報を出力する。

### [0035]

上記訂正回路114から出力されたデータは、信号線ADRS/EDATA[7:0]を介してセレクタ109に入力される。上記セレクタ109は、制御回路300から入力される制御信号HDOSにより選択されたデータを出力する。上記セレクタ109から出力されたデータはフリップフロップ110に入力される。上記フリップフロップ110は、入力されたデータをクロックREo\_CLKでラッチする。上記フリップフロップ110から出力されたデータは、信号線HDO\_REiN[7:0]を介してトライステートバッファ111に入力される。上記トライステートバッファ111は、制御回路300から入力される制御信号HOUTEに基づいてデータの出力を行う。上記トライステートバッファ111から出力されたデータは、上記バスFDHから上記ホスト3へ出力される。

# [0036]

図5は、本実施形態で採用するブロックデータのフォーマットを示す図である。 1 ブロックは、例えば528バイトで構成される。この1 ブロックは、ユーザ領域512バイトと冗長領域16 バイトとに分けられる。例えば、ユーザ領域が16 Mバイトのメモリカードは、上記ブロックを32 K個備える。ECCの符号化方式は、例えばリードソロモン符号を使用し、4 シンボル(1 シンボルが10 ビット)でエラー訂正を行うものとする。ユーザ領域512 バイトのデータに対しては、8 シンボル(80 ビット)、すなわち10 バイトのECCコードを生成する。

### [0037]

図5において、フォーマット0は、ユーザ領域の直後にECCコードを挿入する形式である。フォーマット1は、ユーザ領域の後に1バイトの冗長領域を設け、その後にECCコードを挿入する形式である。フォーマット2は、ユーザ領域の後に2バイトの冗長領域を設け、その後にECCコードを挿入する形式である。フォーマット3は、ユーザ領域の後に3バイトの冗長領域を設け、その後にECCコードを挿入する形式である。フォーマット4は、ユーザ領域の後に4バイトの冗長領域を設け、その後にECCコードを挿入する形式である。フォーマット5は、ユーザ領域の後に5バイトの冗長領域を設け、その後にECCコードを挿入する形式である。フォーマット6は、ユーザ領域の後に6バイトの冗長領域を設け、その後にECCコードを挿入する形式である。

### [0038]

なお、フォーマット6において、ユーザ領域512バイトに更に冗長領域6バイトをユーザに割り当てることも可能である。この場合は、この冗長領域6バイトを加えた保護対象データ518バイトに対して、10バイトのECCコードを生成することも可能である。これにより、518バイトをユーザ領域として使用可能となる。フォーマットの種類と保護対象データの選択(512バイト/518バイト)は、例えばECCコントローラ1内の図示しないモードレジスタにホスト3が予め設定する。本実施形態では、518バイトを保護対象データとしたフォーマット6を使用する。

#### [0039]

以下、図6乃至図11を参照して図2のように構成されたECCコントローラ 1の動作を説明する。

先ず、ホスト3から入力されるコマンド及びアドレスの出力動作を説明する。 図6は、コマンド及びアドレスの出力動作のタイミングチャートを表す図である。

ホスト3がCLE信号を出力し、続いてコマンドCMD、例えばブロックライトコマンドをバスFDHに出力したとする。するとECCコントローラ1は、これを検知してNANDフラッシュメモリ2に対してイネーブルインターフェース/クロックジェネレータ回路200からCLEo信号を出力し、さらに上記ブロックライトコマンドをラッチせずにバスFDNへ出力する。更に、ホスト3がALE信号を出力し、続いてアドレス(ADRS1及びADRS2)をバスFDHに出力すると、ECCコントローラ1はNANDフラッシュメモリ2に対してALEo信号を出力し、さらに上記ADRS1及びADRS2をラッチせずにバスFDNへ出力する。これでデータライトが可能となる。尚、NANDフラッシュメモリ2からデータリードを行う場合も同様である。

#### $[0\ 0\ 4\ 0]$

次に、データの書き込み動作を説明する。図7は、データの書き込み動作のタイミングチャートを表す図である。

ホスト3がバスFDHにライトデータWD1を出力すると、ECCコントローラ1はこのライトデータWD1を上記データパス/訂正回路100に入力する。次にECCコントローラ1は、ライトデータWD1をクロックWE\_CLKの立上がりでラッチして信号線HDI\_WEi[7:0]に出力する。次にECCコントローラ1は、ライトデータWD1をクロックWEo\_CLKの立ち下がりでラッチして信号線NDO\_WEoN[7:0]に出力する。そしてECCコントローラ1は、ライトデータWD1をバスFDNからNANDフラッシュメモリ2に出力する。後続のブロックライトデータWD2及びWD3についても同様の処理を行う。なお、ライトデータを信号線FDHI[7:0]を使用してスルー出力させることも可能である。この場合、ECCコントローラ1は、信号線FDHI[7:0]により転送されるデータを選択する旨の制御信号FDHISを制御回路300から生成し、セレクタ105に入力する。これにより、セレ

クタ105からスルーしたライトデータが出力される。同様の処理が518回繰り返されて6バイトの冗長領域を含む保護対象領域のデータの書き込みが終了する。その後、訂正符号/シンドローム回路113で生成された10バイトのECC コードがバスFDNからNANDフラッシュメモリ2に転送され、528バイトのブロックデータの書き込みが終了する。これに付いては後で詳述する。

### [0041]

次に、NANDフラッシュメモリ2からのデータの読み込み動作を説明する。図8は、データの読み込み動作のタイミングチャートを表す図である。

ホスト3からブロックリードコマンドが送出されるとECCコントローラ1がこれを検知してデータライト時と同様にデータリード可能状態に設定される。

# [0042]

NANDフラッシュメモリ2がバスFDNにリードデータRD1を出力すると、ECCコントローラ1はこのリードデータRD1を上記データパス/訂正回路100に入力する。次にECCコントローラ1は、リードデータRD1をクロックRE\_CLKの立ち上がりでラッチして信号線NDI\_REo[7:0]に出力する。次にECCコントローラ1は、リードデータRD1をクロックREo\_CLKの立下りでラッチして信号線HDO\_REiN[7:0]に出力する。そしてECCコントローラ1は、リードデータRD1をバスFDHからホスト3に出力する。後続のリードデータRD2及びRD3についても同様の処理を行う。なお、ECCコントローラ1がリードデータをラッチせずに出力すると、ECCコントローラ1の内部遅延により、ホスト3でのリードデータ受信時のセットアップマージンが減少する。ECCコントローラ1のリードデータのラッチ処理は、これを回避するために有効である。

### [0043]

次に、保護対象データが518バイトである上記フォーマット6のブロックから構成されるライトデータの書き込み動作を説明する。図9は、上記ライトデータの書き込み動作のフローを示す図である。図10は、上記ライトデータの書き込み動作におけるタイミングチャートを示す図である。

#### [0044]

ホスト3がライトデータの書き込みを行うための命令であるブロックライトコ

マンドを実行したとする。ECCコントローラ1は、バスFDHを介して上記ブロックライトコマンドを検知してデータ書き込み処理を開始すると共に、このブロックライトコマンドをNANDフラッシュメモリ2に出力する。次にECCコントローラ1は、ホスト3が出力したアドレスをNANDフラッシュメモリ2に出力する。

### [0045]

次にECCコントローラ1は、例えば上記ブロックライトコマンドを検知して 518にプリセットされるカウンタ400によりバスFDHから入力されたライト データWD1~WD518のバイト数のカウントを開始する。次にECCコントローラ1は、バスFDHから入力されたライトデータWD1~WD518をックロックWE\_CLKでラッチする。そしてECCコントローラ1は、上記ライトデータWD1~WD518を選択する旨の制御信号NDOSを生成し、セレクタ103に入力する。またECCコントローラ1は、上記ライトデータWD1~WD518を選択する旨の制御信号DINSを生成し、この制御信号DINSをセレクタ112に入力する。

#### $[0\ 0\ 4\ 6]$

ECCコントローラ1は、セレクタ112から出力された上記ライトデータWD1~WD518を基に、上記訂正符号/シンドローム回路113により上記ライトデータWD1~WD518に対するECCコードを生成する。次にECCコントローラ1は、上記生成した10バイトのECCコードCODE1~CODE10を、冗長領域6バイトを含む518バイトの保護対象領域に続いてホスト3が出力した10バイトのダミーライトデータであるインバリッドライトデータ(Invalid Data)の代わりに冗長領域に挿入するための制御信号NDOSを生成し、セレクタ103に入力する。

### [0047]

ECCコントローラ1は、セレクタ103から出力されたECCコードが挿入されたライトデータをクロックWEo\_CLKでラッチする。この際、ECCコントローラ1は、ユーザ領域内の最後のライトデータWD518をラッチした後、クロックWEo\_CLKを1パルス分マスクするため、制御信号MSK\_WEを生成し、NOR回

路209に入力する。このタイミングは、カウンタ400のカウント値を使用して行う。これにより、インバリッドデータ(Invalid Data)をラッチしないようにする。

## [0048]

次にECCコントローラ1は、上記ラッチされたライトデータを選択する旨の制御信号FDHISを生成し、セレクタ105に入力する。ECCコントローラ1は、セレクタ105から出力されたライトデータをNANDフラッシュメモリ2に順次出力する。

### [0049]

一方ホスト3は、自動プログラムコマンドを実行してCLE信号及びWE信号をアサートする。次にホスト3は、NANDフラッシュメモリ2のステータスを検出するためのステータスリードコマンドを実行し、R/B信号をポーリングする。そして、R/B信号がHレベルになるのを検出した時点で、当該ブロックライトデータの書き込みを完了し、必要に応じて次のブロックライトコマンドを実行する。

### [0050]

次に、NANDフラッシュメモリ2からのリードデータの読み込み動作を説明 する。図11は、上記リードデータの読み込み動作のフローを示す図である。

ホスト3がリードデータの読み込みを行うための命令であるブロックリードコマンドを実行したとする。ECCコントローラ1は、バスFDHを介して上記ブロックライトコマンドを検知してデータ読み込み処理を開始すると共に、このブロックリードコマンドをNANDフラッシュメモリ2に出力する。次にECCコントローラ1は、ホスト3が出力したアドレスをNANDフラッシュメモリ2に出力する。次にホスト3は、R/B信号をポーリングし、レディー状態を検出すると、NANDフラッシュメモリ2からリードデータの転送を開始する。

#### [0051]

ECCコントローラ1は、バスFDNから入力されたリードデータ528バイト (リードデータRD1~RD512, 冗長部リードデータRD513~RD51 8, ECCリードデータCODE1~CODE10) をクロックRE\_CLKによりラ ッチする。そしてECCコントローラ1は、このリードデータを選択する旨の制御信号HDOSを生成し、セレクタ109に入力する。またECCコントローラ1は、上記ラッチされたリードデータを選択する旨の制御信号DINSを生成し、セレクタ112に入力する。ECCコントローラ1は、セレクタ112から出力されたリードデータに対して上記訂正符号/シンドローム回路113によりシンドロームを作成する。ECCコントローラ1は、上記シンドロームに基づいて上記訂正回路114においてデータ誤りを判定する。データ誤りが検出されない場合、ECCコントローラ1は、上記正常終了情報を作成する。そしてECCコントローラ1は、この正常終了情報を選択する旨の制御信号HDOSを生成し、セレクタ112に入力する。

### [0052]

一方、データ誤りが検出された場合には、ECCコントローラ1は訂正処理を実行し、誤りデータのアドレスと訂正に必要なデータ情報とからなる訂正情報を作成する。この訂正処理が終了した場合、ECCコントローラ1は上記訂正終了情報を作成する。そして、ECCコントローラ1は上記訂正終了情報及び訂正情報を選択する旨の制御信号HDOSを生成し、セレクタ109に入力する。なお、データ誤りがあった場合において、ECCコントローラ1は5シンボル以上のエラーデータを検出すると、エラー訂正が不可能であると判定し、上記異常終了情報を作成する。そしてECCコントローラ1は、セレクタ109から出力された各データをクロックREo\_CLKによりラッチし、ホスト3に出力する。更に、ECCコントローラ1は、ホスト3からの次のブロックリードコマンドが有ればこれを実行する。

#### [0053]

次に、図2の制御回路300におけるクロックモード制御機能301におけるWE/REクロック代用モードについて説明する。

NANDフラッシュメモリ2としてクロックDCLKを持たないバスプロトコルを使用するメモリカードが用いられる場合には、ECCコントローラ1を駆動するための上記クロックDCLKが得られない。ここで上記クロックDCLKとは、ホスト3から入力されるデータより得られるクロック、或いはホスト3から直接入力されるク

ロックである。このため、ECCコントローラ1は、WE/REクロック代用モードを実行する。WE/REクロック代用モードへの切り替えは、ユーザが例えば外部入力手段から設定してもよいし、ホスト3を経由して設定するようにしてもよい。また、ECCコントローラ1がクロックを持たないメモリカードを検出する機能を備え、自動的に設定するようにしてもよい。

# [0054]

ECCコントローラ1は、WE/REクロック代用モードが選択されると、クロックモード制御機能301からWE信号とRE信号のAND信号をクロックCLKとして選択する旨の制御信号DCLKSELを生成し、上記図3に示したEI/CG回路200内のセレクタ222に入力する。次にECCコントローラ1は、ホスト3からブロックライトコマンドとアドレスが入力されたのを検出すると、上記カウンタ400を起動する。上記カウンタ400は、この時点からWE信号のパルスのカウントを開始する。

### [0055]

次にECCコントローラ1は、上記カウンタ400のカウント値が上記データフォーマットに基づいた所定の値(本実施形態では、1ブロックが528バイトなので、カウント値は528、或いは528にプリセットされた場合はゼロ)になるのを検出すると、パルスをマスクするためにMSK\_WE信号を生成して、上記EI/CG回路200内のNOR回路217に入力する。そして、上記NOR回路217から出力されるWEO信号及びクロックWEO\_CLKは、厳密なタイミングでマスクされる。これにより、ECCコントローラ1は、NANDフラッシュメモリ2のアクセスに必要なパルスのみ選択的に出力し、NANDフラッシュメモリ2のアクセスに不要なパルスを出力しないよう制御することができる。なお、データリード時のRE信号においても同様である。

## [0056]

次に、上記図3を参照して、制御回路300に設けられたCEモード制御機能302におけるスタティックCEモードについて説明する。ECCコントローラ1が例えば3個のNANDフラッシュメモリ2を同時に制御するものとする。ホスト3が3個のNANDフラッシュメモリ2に対して3つのチップイネーブル(

CE)信号を独立に割り当てることが可能なシステムでは、前述した通常のダイナミックCEモードを使用する。このダイナミックCEモードでは、ECCコントローラ1はホスト3から入力された信号CE[3:0]をスルー出力し、指定されたNANDフラッシュメモリ2に信号CEo[3:0]として出力される。ここでは、チップイネーブル信号CE[3:0]は4ビット構成であり、最大で15通りのCE信号とすることができる。

### [0057]

一方、ホスト3が周辺IOデバイスに対して一度に1つのCE信号しかアサートできないシステムであり、3個のNANDフラッシュメモリ2に対して1つのCE信号しか割り当てがない場合には、ECCコントローラ1はスタティックCEモードを実行する。スタティックCEモードの設定方法としては、例えばホスト3がECCコントローラ1に対して設定する。またECCコントローラ1は、ホスト3がCE信号をアサートするのを検出した場合に、スタティックCEモードを設定するようにしてもよい。

## [0058]

スタティックCEモードが選択されると、ECCコントローラ1は、例えばECCコントローラ1に備えられた図示しないモードレジスタをスタティックCEモードに設定する。さらにECCコントローラ1は、スタティックCEレジスタの値であるスタティックCEをIOレジスタに設定する。上記スタティックCEは、CE[3:0]信号と同様に4ビットで構成される。また、上記スタティックCEとして"0"を設定することでCE信号がアサートされる。ECCコントローラ1は、このスタティックCEを上記EI/CG回路200内のセレクタ202に入力する。またECCコントローラ1は、スタティックCEモード信号(STATIC\_CE\_MODE)を生成し、上記EI/CG回路200内のセレクタ202,208,216に入力する。これにより、上記セレクタ202からスタティックCEが出力され、ホスト3はCE[3:0]信号をディアサートしてもNANDフラッシュメモリ2の読み込み処理の継続が可能となる。ホスト3は、NANDフラッシュメモリ2がビジー期間中に、並列処理でNANDフラッシュメモリ2がビジー期間中に、並列処理でNANDフラッシュメモリ2以外のデバイスに対してCE信号をアサートし、そのデバイスにアクセスすることが可能となる

## [0059]

なお、スタティックCEモードでは、3個のNANDフラッシュメモリ2に対して1つのCE信号が割り当てられるが、本実施形態のCE[3:0]信号(4ビット)のうちいずれか1ビットを上記CE信号として割り当てることも可能である。上記割り当てられたCE[3:0]信号のうちの1ビットがアサートされた場合に、NANDフラッシュメモリ2に対してリード或いはライトアクセスが可能となる。上記割り当てられたCE[3:0]信号のうちの1ビットがアサートされた場合のみ、WE信号或いはRE信号がスルーでNANDフラッシュメモリ2に出力される。上記CE[3:0]信号がすべて"H"の場合は、WEo信号或いはREo信号をマスクする。WEo信号或いはREo信号のマスクは、MSK WE信号或いはMSK RE信号により行う。

### [0060]

次に、図2のエラー割り込み制御機能304の割り込み処理の動作について説明する。

NANDフラッシュメモリ2からホスト3へのブロックリードデータの読み込みが終了すると、ECCコントローラ1は、"ff"データを図4の上記データパス/訂正回路100内のセレクタ109に入力し、バスFDHから上記"ff"データをホスト3に出力する。これにより、ECCコントローラ1は、ホスト3に対してエラー検出処理中であることを通知する。所定サイクル後、ECCコントローラ1は、エラーの有無を表す"エラー有無情報"を作成し、ホスト3に対してこの"エラー有無情報"を1サイクル出力後、再び"ff"データをホスト3に出力し続ける。所定サイクル後、ECCコントローラ1は、エラーの数を表す"エラー見積もり数情報"を作成し、ホスト3に対してこの"エラー見積もり数情報"を1サイクル出力後、再び"ff"データをホスト3に出力し続ける。所定サイクル後、ECCコントローラ1は、エラー訂正が正常に完了したことを表す"エラー訂正完了正常終了情報"を作成し、ホスト3に対してこの"エラー訂正完了正常終了情報"を作成し、ホスト3に対してこの"エラー訂正完了正常終了情報"を作成し、ホスト3に対して10なかった場合、"エラー訂正不可能異常情報"を作成し、ホスト3に対して1

# [0061]

ここで、上記処理が非割り込みモードでの処理の場合、"エラー訂正完了正常終了情報"ならば引き続きエラーアドレス及び訂正に必要なデータ情報をホスト3に出力し、処理を終了する。"エラー訂正不可能異常情報"ならば、そのまま処理を終了する。

## [0062]

一方、上記処理が割り込みモードでの処理の場合、ECCコントローラ1は"エラー訂正完了正常終了情報"ならば、割り込み(INTN)信号をアサートし、上記"エラー訂正完了正常終了情報"をバスFDNに出力し続ける。ホスト3は、割り込みを受け付けると、割り込み内容情報を取得し、ECCコントローラ1に対して割り込み許可である旨のアクノリッジコマンドを出力する。ECCコントローラ1は、上記アクノリッジコマンドをマスクして、NANDフラッシュメモリ2に出力しない。ECCコントローラ1は、上記アクノリッジコマンドが入力されると、上記INTN信号をディアサートし、RE信号に同期してエラーアドレス及び訂正に必要なデータ情報を順次出力する。ECCコントローラ1は、上記エラーアドレス及び訂正に必要なデータ情報をすべて出力すると、処理を終了する。

#### [0063]

また、"エラー訂正不可能異常情報"ならば、ホスト3は、割り込みを受け付けると、割り込み内容情報を取得し、ECCコントローラ1に対して上記アクノリッジコマンドを出力する。ECCコントローラ1は、上記アクノリッジコマンドが入力されると、上記INTN信号をディアサートし、処理を終了する。

# [0064]

次に、図2のECC領域制御機能303に含まれるECCコード格納領域可変機能の動作について説明する。

上記ECCコントローラ1は、上記図5に示したブロックデータの各フォーマットのうち、ECCコードを挿入する領域を冗長領域内の任意の場所に指定できる機能を備える。フォーマット情報の選択方法としては、ECCコントローラ1に入力手段を設け、ユーザが設定するようにしてもよいし、ユーザが選択したフォーマット情報をホスト3がECCコントローラ1に設定するようにしてもよい

。例えばホスト3が、ECCコントローラ1内のモードレジスタにフォーマット情報を書き込んだとする。ECCコントローラ1は、上記カウンタ400がカウントする値が、上記設定されたフォーマットにより決められる値になった時点で、上記訂正符号/シンドローム回路113が作成したECCコードを順次挿入する。例えば上記図5に示したフォーマット1の場合、カウント値が513になった時点でECCコードの挿入を開始する。この処理は、セレクタ103に入力される制御信号NDOSのタイミングを制御することにより行う。

## [0065]

次に、図2の専用コマンド実行モード制御機能305におけるECCコントローラ専用コマンド実行モードについて説明する。

ECCコントローラ1の専用コマンドを定義する場合、メモリカードのコマンドセットの中の未使用コードを専用コマンドとして割り当てる必要がある。この場合、ECCコントローラ1の専用コマンド数が限定されるため、ECCコントローラ1の多機能化の弊害となる。この実施形態では、専用コマンドを2つ使用するだけで、ECCコントローラ1の専用命令を実行する。例えばECCコントローラ1の専用コマンドとして、コマンド90(CMD90)とコマンド91(CMD91)を定義する。ホスト3がCMD90を実行するとECCコントローラ1専用コマンド実行モードに入り、CMD91を実行するとECCコントローラ1専用コマンド実行モードから抜ける。ECCコントローラ1専用コマンド実行モードから抜ける。ECCコントローラ1専用コマンドを出力しない機能を備える。

### [0066]

具体的には、上記EI/CG回路200内のNOR回路209に入力するマスク信号(MSK\_WE)を制御し、NANDフラッシュメモリ2に出力されるWEo信号を、ホスト3が出力するWE信号に関わらずディアサートする。また、上記EI/CG回路200内のNOR回路217に入力するマスク信号(MSK\_RE)を制御し、NANDフラッシュメモリ2に出力されるREo信号を、ホスト3が出力するRE信号に関わらずディアサートする。これにより、ホスト3によりCMD90が実行されると、ホスト3はECCコントローラ1に対してメモリカードのコマンド

セットと同一のコードを使用して、ECCコントローラ1に命令を実行することが可能となる。よって、多くのECCコントローラ1専用コマンドを定義して、ECCコントローラ1の多機能化を実現できる。

## [0067]

以上詳述したようにこの実施形態では、ホスト3とNANDフラッシュメモリ2間のバスをECCコントローラ1が中断するアーキテクチャにしている。よって、例えば多値化データに対応して機能を強化したECC回路を追加する場合に、ホスト3及びNANDフラッシュメモリ2の設計変更等が不要になる。

## [0068]

ECCコントローラ1は、ECCコントローラ1の内部遅延時間を等しく揃え、かつホスト3が出力する制御信号とECCコントローラ1が出力する制御信号とで二重にラッチしている。よって、ホスト3或いはNANDフラッシュメモリ2は、データ受信時のタイミングマージンを確保することができる。また、ホスト3から入力されたデータをラッチするか、スルー出力するかを選択することができるので、データの種類により自由に対応することが可能である。

## [0069]

又、ECCコントローラ1は、バス監視機能を備えているので、システムにE CCコントローラ1の専用コマンドを新規に追加しなくても、自動的にECC機 能を付加することができる。

## [0070]

さらに、クロックを持たないメモリカードなどに用意されたバスプロトコルに ECCコントローラ1を適用する場合でも、例えばライトイネーブル信号或いは リードイネーブル信号をクロックとして代用することができるため、クロックが 無いシステムにもECCコントローラ1を追加することができる。また、メモリ カードに必要なライトイネーブル信号或いはリードイネーブル信号のみをメモリ カードに出力するようにしているので、不要なライトイネーブル信号或いはリー ドイネーブル信号がメモリカードに入力され、メモリカードが誤動作することを 防止できる。

### [0071]

また、ホスト3が例えばIOデバイスに対して1つのチップイネーブル信号しかアサートできないシステムにおいて、ECCコントローラ1がホスト3に代わってチップイネーブル信号をアサートする機能を備えている。よって、ホスト3が他のデバイスに対してチップイネーブル信号をアサートしても、NANDフラッシュメモリ2のアサートを継続して行うことができる。これによりホスト3は、NANDフラッシュメモリ2をアサート中に、他のデバイスにアクセスして並列処理を行うことが可能となる。

## [0072]

ECCコントローラ1は、割り込み線をアサート時に同時に割り込み内容情報をバスに出力し続ける機能を備えている。よって、割り込み通知と割り込み内容を同時にホスト3に通知することができ、ホスト3はNANDフラッシュメモリ2のIOレジスタにアクセスする処理を省くことで、ホスト3の処理効率を向上できる。

### [0073]

ECCコントローラ1は、ECCコードを挿入する領域を変更する機能を備えている。よって、NANDフラッシュメモリ2の多種類のデータフォーマットに柔軟に対応することができる。

# [0074]

ECCコントローラ1は、ホスト3から入力された所定の専用コマンドをマスクしてNANDフラッシュメモリ2に出力しない機能を備えている。よってホスト3は、NANDフラッシュメモリ2のコマンドセットと同一のコードを使用して、ECCコントローラ1に命令を実行することが可能となる。これにより、多くのECCコントローラ1専用コマンドを定義して、ECCコントローラ1の多機能化を実現できる。

#### [0075]

この発明は、上記実施形態に限定されるものではなく、メモリカード以外のメモリ、例えば半導体メモリに適用でき、その他、本発明の要旨を変更しない範囲において種々変形して実施可能なことは勿論である。

#### [0076]

### 【発明の効果】

以上詳述したように本発明によれば、新たなエラー訂正手段を追加する際に、ホスト或いはメモリ例えばメモリカードなどの半導体メモリにおける既存の回路等を変更することなく、且つホストの負担を増やすことなくECCの機能強化が可能なECC制御装置を提供することができる。

# 【図面の簡単な説明】

#### 【図1】

この発明の実施形態における全体構成を示すブロック図。

## 【図2】

図1に示したECCコントローラ1の内部構成を示すブロック図。

# 【図3】

図2に示したイネーブルインターフェース/クロックジェネレータ回路200 の回路構成を示すブロック図。

#### 【図4】

図2に示したデータパス/訂正回路100の回路構成を示すブロック図。

#### 【図5】

本実施形態で採用するブロックデータのフォーマットを示す図。

### 【図6】

図1に示したECCコントローラ1におけるコマンド及びアドレスの出力動作のタイミングチャートを示す図。

#### 【図7】

図1に示したECCコントローラ1におけるデータの書き込み動作のタイミングチャートを示す図。

#### 【図8】

図1に示したECCコントローラ1におけるデータの読み込み動作のタイミングチャートを示す図。

#### 【図9】

図1に示したECCコントローラ1におけるライトデータの書き込み動作のフローを示す図。

### 【図10】

図1に示したECCコントローラ1におけるライトデータの書き込み動作のタイミングチャートを示す図。

### 【図11】

図1に示したECCコントローラ1におけるNANDフラッシュメモリ2からのリードデータの読み込み動作のフローを示す図。

## 【符号の説明】

1…ECCコントローラ、2…NANDフラッシュメモリ、3…ホスト、100…データパス/訂正回路、101,107…バッファ、102,104,108,110…フリップフロップ、103,105,109,112…セレクタ、106…トライステートバッファ、111…トライステートバッファ、113…訂正符号/シンドローム回路、114…訂正回路、200…イネーブルインターフェース/クロックジェネレータ回路、201…インバータ回路、202,208,216,222…セレクタ、203,205,210,213,218,223,225,227…遅延回路、204,206,212,214,224,226,228…バッファ、207,215…ゲート回路、209,217…NOR回路、211,219…インバータ回路、221…AND回路、300…制御回路、301…クロックモード制御機能、302…CEモード制御機能、303…ECC領域制御機能、304…エラー割り込み制御機能、305…専用コマンド実行モード制御機能、400…カウンタ。

【書類名】

図面

【図1】



【図2】



【図3】



【図4】



【図5】



【図6】



【図7】



【図8】



【図9】



【図10】



【図11】



【書類名】

要約書

【要約】

【課題】ホスト或いはメモリカードにおける既存の回路等を変更することなく、 ECCの機能強化を可能とする。

【解決手段】ホスト3とNANDフラッシュメモリ2との間のバスを中断する形でECCコントローラ1を挿入する。ECCコントローラ1は、ホスト3から入力された所定単位のブロックデータのうち、ユーザ領域と冗長領域とを検出し、上記ユーザ領域に対してECCコードを作成する。そして、この作成したECCコードを上記冗長領域に挿入してNANDフラッシュメモリ2に出力する。一方、NANDフラッシュメモリ2から入力された上記ブロックデータに対してシンドローム演算を行い、訂正処理を実行する。そして、上記ブロックデータと上記訂正処理を結果をホスト3に出力するようにしている。

【選択図】 図2

# 特願2003-054686

# 出願人履歴情報

識別番号

[0000221199]

1. 変更年月日

1990年 8月23日

[変更理由]

新規登録

住 所 氏 名

神奈川県川崎市川崎区駅前本町25番地1

東芝マイクロエレクトロニクス株式会社

# 出願人履歴情報

識別番号

[000003078]

1. 変更年月日 [変更理由]

2001年 7月 2日 住所変更

住所

東京都港区芝浦一丁目1番1号

氏 名 株式会社東芝

-